<template>
  <!-- 一条文章单元格 -->
  <!-- 可以在<van-cell>里绑定点击事件  @click='cellClickFn'因为文档里支持 但是我们要想到万一不支持click方法，该怎么办？
    解决方法：可以在SearchResult组件里写-->
  <van-cell>
    <!-- 标题区域的插槽 -->
    <template #title>
      <div class="title-box">
        <!-- 标题 -->
        <span>{{ artObj.title }}</span>
        <!-- 单图 -->
        <img
          v-if="artObj.cover.type === 1"
          class="thumb"
          v-lazy="artObj.cover.images[0]"
          alt=""
        />

      </div>
      <!-- 多图 -->
      <div class="thumb-box" v-if="artObj.cover.type > 1">
        <img
          v-for="(imgUrl, index) in artObj.cover.images"
          :key="index"
          class="thumb"
          v-lazy="imgUrl"
          alt=""
        />
      </div>
    </template>
    <!-- label 区域的插槽 -->
    <template #label>
      <div class="label-box">
        <div>
          <span>{{ artObj.aut_name }}</span>
          <span>{{ artObj.comm_count }}评论</span>
          <span>{{ formatTime(artObj.pubdate) }}</span>
        </div>
        <!-- 关闭按钮 @click.stop阻止冒泡，否则点击叉叉会触发打开详情页而不是反馈页-->
        <van-icon name="cross" @click.stop="show = true" v-if="isShow" />
        <van-action-sheet
          v-model="show"
          :actions="actions"
          @select="onSelect"
          @cancel="cancelFn"
          @close="closeFn"
          :cancel-text="bottomText"
          get-container="body"
        />
      </div>
    </template>
  </van-cell>
</template>

<script>
// 目标1: 点击"反馈垃圾内容"数据的切换
// 1. 监听点击事件, 区分用户点击的是哪一个
// 2. 切换actions数组里数据

// 目标2: 二级反馈数据出现, 取消按钮文字要换成"返回"
// :cancel-text="bottomText" 设置变量, onSelect中, 把变量值换成"返回"

// 目标3: 点击底部按钮, 要区分判断
// 1. 标签@cancel取消事件和事件方法
// 2. 在里面用bottomText的值, 判断用户点击的是否为"返回"
// 把actions数据源换会成firstActions
// bottomText文字换成"取消"
// 强制让反馈面板show = true留下
import { timeAgo } from '@/utils/date.js'
import { firstActions, secondActions } from '@/api/report.js'
export default {
  props: {
    artObj: {}, // 文章对象  写Object也可以
    isShow: {
      type: Boolean,
      default: true // 例如首页的地方我不想再去动了, 首页肯定没传isShow值进来, 所以首页需要显示
    }
  },
  data () {
    return {
      show: false, // 反馈面板显示/隐藏
      actions: firstActions, // 反馈面板选项数组(套对象)
      bottomText: '取消',// 底部按钮的文字
    }
  },
  methods: {
    formatTime: timeAgo, // 函数体是timeAgo
    // 反馈面板-"选项"选择事件
    onSelect (action, item) {
      // console.log(action) // {name: '反馈垃圾内容'}  
      // console.log(item) // 索引值
      // 默认情况下点击选项时不会自动收起
      // 可以通过 close-on-click-action 属性开启自动收起
      // this.show = false
      if (action.name === '反馈垃圾内容') {
        this.actions = secondActions
        this.bottomText = '返回'
      } else if (action.name === '不感兴趣') {
        this.$emit('disLikeEV', this.artObj.art_id)
        this.show = false // 无论成功/失败-直接让反馈面板隐藏
      } else {
        // 二级反馈选项  action.value是report.js中的value值，是个数字类型
        this.$emit('reportEV', this.artObj.art_id, action.value)
        this.show = false // 关闭-下面cancel会帮你把反馈选项切回来
      }
    },
    // 反馈面板-底部按钮-点击事件
    cancelFn () {
      if (this.bottomText === '返回') {
        this.show = true // 强制让它回来
        this.actions = firstActions
        this.bottomText = '取消'
      }
    },
    // 反馈面板-关闭面板-触发事件  防止在二级面板点击蒙层时自动关闭然后再次打开面板出现二级面板内容的现象   所以要重新赋值
    closeFn () {
      this.actions = firstActions
      this.bottomText = '取消'
    }
  }
}
</script>

<style scoped lang="less">
.van-cell{
  padding: 6px 14px;
}
/* 标题样式 */
.title-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* label描述样式 */
.label-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* 文章信息span */
.label-box span {
  margin: 0 3px;
  &:first-child {
    margin-left: 0;
  }
}

/* 图片的样式, 矩形黄金比例：0.618 */
.thumb {
  width: 113px;
  height: 70px;
  background-color: #f8f8f8;
  object-fit: cover;
}

/* 三图, 图片容器 */
.thumb-box {
  display: flex;
  justify-content: space-between;
}
</style>
